import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

import RouterConfig from './routes/RouterConfig'
import RouterZeroCode from './routes/RouterZeroCode'
import RouterMall from './routes/RouterMall'
import RouterUser from './routes/RouterUser'
import RouterSystem from './routes/RouterSystem'
import CommonRouter from './commonRouter'
import RouterNotes from './routes/RouterNotes'

/** note: Submenu only appear when children.length>=1
 *  submit see  https://panjiachen.github.io/vue-element-admin-site/guide/essentials/router-and-nav.html
 **/

/**
 * hidden: true                   if `hidden:true` will not show in the sidebar(default is false)
 * alwaysShow: true               if set true, will always show the root menu, whatever its child routes length
 *                                if not set alwaysShow, only more than one route under the children
 *                                it will becomes nested mode, otherwise not show the root menu
 * redirect: noredirect           if `redirect:noredirect` will no redirect in the breadcrumb
 * name:'router-name'             the name is used by <keep-alive> (must set!!!)
 * meta : {
    perms: ['GET /aaa','POST /bbb']     will control the page perms (you can set multiple perms)
    title: 'title'               the name show in submenu and breadcrumb (recommend set)
    icon: 'svg-name'             the icon show in the sidebar,
    noCache: true                if true ,the page will no be cached(default is false)
  }
 **/
export const constantRouterMap = CommonRouter
export default new Router({
  scrollBehavior: () => ({ y: 0 }),
  routes: constantRouterMap
})

export const asyncRouterMap =
  [
    ...RouterConfig,
    ...RouterMall,
    ...RouterUser,
    ...RouterSystem,
    ...RouterNotes,
    ...RouterZeroCode,
    ...[
      { path: '*', redirect: '/404', hidden: true }
    ]
  ]
